CLAIMS 



We claim: 



1. A method for producing a circuit description of a design, the method comprising: 



a) from\he design, selecting a candidate sub-network; 



u 
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b) identifying a set of output functions performed by the sub-network; 

c) based ontthe identified set of output functions, retrieving a replacement sub- 
network from a storage structure that stores replacement sub-networks; 



u 
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d) determining whether to replace the selected candidate sub-network with the 
replacement sub-network in the design; 

e) if determine to replace the selected candidate sub-network, replacing the selected 



candidate sub-network with the replacement sub-network in the design. 



2. The method of claim 1, wherein the set of output functions includes only one output 



function. 



3. The method of claim 1, wherein the set of output functions includes a plurality of 



15 output functions. 



4. The method of claim 1, wherein the candidate sub-network includes multiple circuit 



elements. 



5. The mfethod of claim 1, wherein the storage structure stores sub-networks up to a 
particular complexity. 

\ 6. A method for producing a circuit description of a design, the method comprising: 

a) from the design, selecting a candidate sub-network that performs a plurality 
output functions, wherein the candidate sub-network includes a set of circuit elements; 

\ 

b) generating a parameter based on the output functions; 



c) using the paran^eter to retrieve a replacement sub-network from a storage structure 
that stores replacement sub-networks; 

\ 

d) replacing the selected candidate sub-network with the replacement sub-network in 

the design. 



7. The method of claim 6 further comprising identifying the output functions performed 
by the sub-network. 

\ 

8. The method of claim 6, wherein the set of circuit elements includes only one circuit 
element. 

9. The method of claim 6, wherein t\\ set of circuit elements includes at least two circuit 
elements. 

10. The method of claim 6, wherein each circuit element of the sub-network has an 
output, and each circuit element's output provides a Vesult of one output function performed by 

the selected candidate sub-network. \ 

\\ 
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11. The method of claim 6, wherein each circuit element of the sub-network has an 
output, and each output function performed by the selected candidate sub-network is provided at 
only a circuit-element output that fans out of the sub-network. 

12. The methooof claim 6 further comprising: 

\ 

receiving a local function for each circuit element of the selected candidate sub- 



network; 



identifying eachbutput function from the received local functions. 

\ 

13. The method of clarm 12 wherein each local or output function is represented in terms 



of a binary decision diagram ("BDD"), and the sub-network has at least first and second circuit 
elements, wherein the first circuit^element performs a first local function, and the second circuit 
element performs a second local function, wherein the BDD of a first output function is derived 
from the BDD of the first local function, and the BDD of a second output function is derived 



from the BDD's of at least the first and second local functions. 

\ 

14. The method of claim 6 further comprising 

receiving the design, wherein the design is a combinational-logic network, 



selecting additional candidate subnetworks; 

replacing some of the selected additional sub-networks with replacement sub- 
networks retrieved from the storage structure; 
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whereirathe replacement of the candidate sub-networks optimizes the combinational- 
logic network design. 

15. The methoa of claim 6 further comprising 
receiving a logical representation of the design; 

converting the logical representation of the design to a circuit-level representation; 

\ 

wherein selecting the candidate sub-network includes selecting the candidate sub- 
network from the circuit-level representation. 

16. The method of claim 6, wherein the parameter is a set of indices for storing the sub- 

\ 

network in the storage structure, wherein the set of indices includes an index for each output 

\ 

function performed by the sub-network. 



17. The method of claim 16, wherein using the parameter comprises: 

\ 

a) identifying each replacement sub-network stored in the storage structure that is 

\ 

associated with each index in the set of indices; and 



b) retrieving each identified replacement sub-network. 

\ 

18. The method of claim 16, wherein the indices are numerical indices. 

V 

\ 

19. The method of claim 18, wherein the storage structure is a relational database, and the 

v, 

set of indices are indices into the relational database. 



\ 
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20. The mdthod of claim 16, wherein the candidate sub-network has a set of input 
variables, wherein Generating the parameter comprises: 

a) identifying one of the output functions as a pivot function; 

b) using the pivot function to specify a configuration for the input variables, 



c) based on the specified input-variable configuration, specifying an index for each 



function. 



\\ 

21. The method of claim 20, wherein using the pivot function to specify an input-variable 

configuration comprises: \ 

\\ 
\\ 

a) identifying a canonic representation of the pivot function; 

b) selecting an input-variable configuration that results in the canonic representation 



of the pivot function as the specified input-variable configuration. 
22. The method of claim 21 furtler comprising: 



a) generating a truth table representation of the pivot function; 

b) wherein identifying the canonic representation includes identifying a canonic 
representation of the truthtable representatio3bf the pivot function. 

23. The method of claim 21 further comprising condensing the canonic representation to 
obtain a condensed representation of the pivot function. 
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24. Tqkmethod of claim 22 further comprising using the specified input-variable 
configuration tolspecify a truthtable representation for each non-pivot function of the sub- 
network, wherein the index of each non-pivot function is specified based on the truthtable 
representation of the non-pivot function. 
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25. The method of claim 21 further comprising: 

\ 

specifying akondensed representation of each non-pivot function based on the 
selected input-variable configuration. 

26. The method of Glaim 20, wherein the index of the pivot function is a primary index, 
and the index of each non-pi^ot function is a secondary index, wherein using the parameter 
comprises: 

a) for each particulaiundex pair formed by the primary index and one of the 
secondary indices, identifying eacnireplacement sub-network stored in the storage structure that 
is associated with the particular index pair; 



b) determining whether any of the identified replacement sub-networks are 
15 associated with all the index pairs; 



c) retrieving any identified replacement sub-network that is associated with all index 



pairs. 



27. The method of claim 6 further comprising: 



before i ^placing the candidate sub-network with the replacement sub-network, 
evaluating whether t$ replace the selected candidate sub-network with the replacement sub- 
network, 

wherein saidVeplacing is based on the evaluation. 

— — _ — 

29. The method of claim 27 further comprising: 



selecting additional candidate sub-networks; 

\ 

identifying a replacement sub-network for each selected candidate sub-network; 



\ 



evaluating each identified replacement; 

\ 

based on the evaluations^ replacing some of the candidate sub-networks with the 



replacement sub-networks identified W the candidate sub-networks. 

\ 

30. The method of claim 27, \ 



wherein retrieving the replacement sub-network comprises retrieving several 

•\ 

replacement sub-networks, the method further comprising: 

\ 

evaluating each retrieved sub-network to identify viable replacement candidates; 

wherein the replacement sub-network that replaces the candidate sub-network is one 
of the viable replacement candidates. 



